草庐IT

php - 为什么在我们有 json_encode 时使用 CJSON 编码

全部标签

ruby - Rails 使用什么 sleep()?

我正在测试一段Rails代码,上面写着:sleep(10.0)在我的RSpec测试中,调用:Kernel.should_receive(:sleep).exactly(1).time失败,测试休眠了十秒。这使我得出结论,Rails程序中的sleep()并未调用Kernel.sleep()。我通过将我的Rails代码更改为以下内容来验证这一点:Kernel.sleep(10.0)...之后我的RSpec测试通过了(并且测试没有休眠)。这引出了一个具体的和一般的问题:Rails使用什么sleep()实现(我运行的是Ruby1.9.3/Rails3.2.1)?对于解释器,找到任何函数的源代码

ruby - 方法调用中括号的使用规则是什么?

在调用方法时,我不能在以下情况中省略括号:t=[]t.push{}#=>[]#Iexpected[{}]t.push({})#=>[{}]我应该应用什么规则来避免这种情况? 最佳答案 当您将{}作为唯一参数传递时(因此调用中没有逗号),Ruby无法判断您的意思是空散列还是空block,因此您需要使用括号区分它:t.push(){}t.push({})在其他情况下,根据经验,如果您直接将方法调用用作参数,则需要括号,即methodarg0,arg1,other_method(arg01,arg02),arg2,arg3当您的方法调用变

ruby - 为什么 "23 Dogs"在 pry 中被解析为 2015 年 11 月 23 日,但 "3 Dogs"给出解析器错误?

我在Twitter上找到了以下代码片段(查看帖子历史以获取来源)。[5]pry(main)>Date.parse('3Dogs')ArgumentError:invaliddate[6]pry(main)>Date.parse('23Dogs')=>Mon,23Nov2015这只是一个偷偷摸摸的彩蛋吗?如果是这样,为什么这个特定的日期和结果?如果不是彩蛋,为什么23Dogs解析为日期,但3Dogs不解析? 最佳答案 这与Pry无关。如果您检查Date::parse的文档你会看到,“如果可选的第二个参数[comp]为真[默认值]并且检

ruby - Ruby 中绑定(bind)/解除绑定(bind)方法的目的是什么?

Method#unbind和UnboundMethod#bind的目的是什么?据我所知,方法是像procs和lambdas这样的可调用对象,除了方法绑定(bind)到它们的接收者的范围之外:classSomeClassdefa_method;puts"fromSomeClass";endends=SomeClass.news.a_method#=>"fromSomeClass"如果我在SomeClass的上下文中或者我有一个SomeClass的对象,我可以调用a_method。我可以通过将方法提取为Method对象使其成为可调用对象,但在此示例中它仍然绑定(bind)到SomeClas

arrays - 为什么 Dir.glob ("*.txt").sort 也需要 .each?

Dir.glob("*.txt"){|f|pf}打印文件名。Dir.glob("*.txt").sort{|f|pf}因ArgumentError失败。Dir.glob("*.txt").sort.each{|f|pf}按字母顺序打印文件名。为什么第二个失败了?更好的是,为什么第一个工作,有或没有.each?Dir.glob和Dir.glob.sort都是数组。Dir.glob.methods==Dir.glob.sort.methods。(受AlphabetizeresultsofDir.glob启发。不是Dir.globwithsortissue的副本,因为“第三个”已经回答了那个

ruby - 与 block 一起使用时,ruby Hash#merge 的行为是什么

它似乎没有被记录很多:hsh.merge(other_hash){|key,oldval,newval|block}→a_hashhttp://ruby-doc.org/core/classes/Hash.html#M002880 最佳答案 正如预期的那样,生成的散列将包含一个block返回的值,该block针对存在于两个正在合并的散列中的每个键:>>h1={:a=>3,:b=>5,:c=>6}=>{:a=>3,:b=>5,:c=>6}>>h2={:a=>4,:b=>7,:d=>8}=>{:a=>4,:b=>7,:d=>8}>>h1

ruby-on-rails - 为什么我应该只在测试环境而不是开发或生产环境中在我的 Rails 应用程序上运行 rspec 规范?

有人告诉我,除了测试之外,我不应该在rails_env中运行我的rspec规范。在生产或开发中运行规范的潜在问题是什么?我在两者中都运行规范。我通常在开发中运行规范,除非我正在测试使用Assets管道的东西。我为此切换到生产环境并花费15分钟预编译Assets。与我当前的方法相比,使用测试环境有什么优势吗?我搜索了答案,但没有任何内容解释为什么我不应该使用dev或prod。 最佳答案 在test环境中运行测试套件(例如rspec)旨在隔离资源以解决安全问题,尤其是数据库的完整性。测试通常会损坏或完全删除数据库中的数据。这同样适用于所

ruby-on-rails - 访问父对象属性的 "rails way"是什么?

假设我有一个模型Doctor和一个模型Patient。Patientbelongs_toaDoctor。一个Doctor有一个属性office。我想,给定一个Patientp,能够说p.office并访问p的office的医生。我总是可以写一个方法classPatientbelongs_to:doctordefofficeself.doctor.officeend但是有没有一种更自动的方法可以将Doctor的所有属性方法公开给Patient?也许使用method_missing来获得某种包罗万象的方法? 最佳答案 你可以使用dele

ruby - 为什么日期之间的减法会返回 Rational 类型?

我正在尝试对日期执行减法运算。date_sent=Date.parse("2013-01-01")#=>Tue,01Jan2013date_now=Date.today#=>Wed,04Sep2013days=(date_now-date_sent)#=>(246/1)为什么date_now-date_sent返回一个Rational类型? 最佳答案 这是预期的行为。来自docs:d-other→dateorrationalDate.new(2001,2,3)-1#=>#Date.new(2001,2,3)-Date.new(200

ruby - `Kernel` 的目的是什么?

Kernel模块的用途是什么?如果当前在Kernel上定义的所有内容都在Object上定义,并且没有Kernel这样的模块,会有什么变化?当我想定义一个可以在任何对象上调用的方法时,我应该在Kernel上还是在Object上定义它? 最佳答案 我将从一个问题开始:self在一个典型的Kernel中会是什么?puts之类的方法?puts中最接近有意义的self的可能是Ruby运行时本身。同样对于其他“真正想成为函数的方法”,如Array或fork.因此,您可以将Kernel视为方法的垃圾场,这些方法或多或少是Ruby本身的命令或消息。